package com.insight.modules.system.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.insight.common.api.vo.Result;
import com.insight.modules.system.entity.SysRole;
import com.insight.modules.system.entity.SysThreePowerMenu;
import org.jeecgframework.poi.excel.entity.ImportParams;
import org.springframework.web.multipart.MultipartFile;

import java.util.List;

/**
 * <p>
 * 角色表 服务类
 * </p>
 *
 * @Author scott
 * @since 2018-12-19
 */
public interface ISysRoleService extends IService<SysRole> {

    /**
     * 导入 excel ，检查 roleCode 的唯一性
     *
     * @param file
     * @param params
     * @return
     * @throws Exception
     */
    Result importExcelCheckRoleCode(MultipartFile file, ImportParams params) throws IOException;

    /**
     * 删除角色
     * @param roleid
     * @return
     */
    public boolean deleteRole(String roleid);

    /**
     * 批量删除角色
     * @param roleids
     * @return
     */
    public boolean deleteBatchRole(String[] roleids);

    /**
     * 通过角色编码获取要显示的菜单
     * @param roleCode 角色编码
     * @return
     */
    List<SysThreePowerMenu> getSysThreepowerMenueByRoleCode(String roleCode);

    /**
     * 通过显示类型获取菜单
     * @param showType 显示类型
     * @return
     */
    List<SysThreePowerMenu> getSysThreepowerMenueByShowType(String showType);

    SysRole getInfoByRoleCode(String relateId);

    List<SysRole> getInfoByUserId(String id);

    Boolean hasButtonRole(String role,String userId);
}
